Specify a minimum version of AWNPipe you need. The format is /-VVRRR where V is the version and R is the revision.
AWNPipe:name/-02009 will fail to open unless AWNPipe is version 2.9 or newer.
A option
========
Abort pending reads. When developing programs that use AWNP it is common to make an error and have pending reads on both ends of you pipe. The pipe hangs and so does your program. If you open the pipe a third time using the '/a' option the pending reads are aborted. The pipe is no longer hanging and your program should exit. The third open itself ALWAYS fails.
M option
========
Multiple opens. When a pipe is opened it behaves normaly. However when this file handle is closed that end of the pipe becomes available to be opened again. If the 'open first end' (/1) flag is set the open call only tries to open the first side of the pipe (the end that was opened when the pipe was created).If the donotwait flag is set the open cal only tries to open the second side of the pipe (the end that was NOT opened first). When neither flag is set you get the first end of the pipe if available, else you get the second end.
I option
========
Immediate reads. Reads to the file handle will return if there is any data waiting to be read. Therefore only a read of 0 length means end of file. This is useful with data originating interactively from con: or ser: .
F option
========
Force a pipe to be created. A new pipe is created even if the pipe name is already is use. The open will not fail, and it will not connect to any currently existing pipe end. After both ends of the forced pipe are completed any previous partial ( only opened once) pipe of that name becomes available again.
! or ~ option.
==============
Do not wait. The open will fail unless the other end of the pipe is already open. A new pipe will not ever be created. Used on a tap it stops the tap from waiting for a matching pipe to be created.
@ option
==============
Respond to seek packets. Normaly seek is not supported by AWNPipe. If see is
turned on, the current position is reported as '0' if no data is available on
the pipe, '1' if data is waiting to be read.
NOTE Do not use this function from ARexx as ARexx has a read ahead buffer
that is flushed when you call seek. This can cause you to loose data. It may
also happen in other languages if read data is buffered.
S or s option
==============
Status of a pipe. This MUST always be a tap as well. Read only returns a single byte. This is the status of the real pipe the tap refers to. The bits/nibbles or byte meanings are as follows.
'FF' indicates file handle does not exist. (you can check just the high bit)
low nibble = First end that is opened.
high nibble =second end opened.
in each nibble
bit 4 always zero when FH exists
bit 3 FH opened. (nibble&4)
bit 2 FH closed. (nibble&2)
bit 1 FH data available. (nibble&1) sub for WaitForChar in AREXX.